<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <h1>注册</h1>
  用户名：<input type="text" id="username">
  <br>
  密码：<input type="text" id="password">
  <br>
  手机号：<input type="text" id="phone">
  <br>
  邮箱：<input type="text" id="email">
  <br>
  身份证号：<input type="text" id="idcard">
  <br>
  <button id="reg">注册</button>


  <script>
    // 表单验证  正则
    var reg = document.getElementById("reg")

    reg.onclick = function (e) {

      // 获取各个输入框的值
      var usernameVal = document.getElementById("username").value;
      var passwordVal = document.getElementById("password").value;
      var phoneVal = document.getElementById("phone").value;
      var emailVal = document.getElementById("email").value;
      var idcardVal = document.getElementById("idcard").value;
      // 正则
      var userReg = /^\w{6,10}$/  //6到10位的数字字母下划线
      var passwordReg = /^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$/  //必须包含大写字母 小写字母 数字
      var emailReg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
      var phoneReg = /^1(3|4|5|6|7|8|9)\d{9}$/;
      var idCardReg = /^[1-9]\d{5}(18|19|20|(3\d))\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/
      // test() 

      var flag = true;
      if (usernameVal && passwordVal && phoneVal && emailVal && idcardVal) {
      } else {
        alert("所有数据不能为空")
        return
      }

      if (!userReg.test(usernameVal)) {
        flag = false;
        alert("用户名6到10位的数字字母下划线")
      }
      if (!(passwordReg.test(passwordVal))) {
        flag = false;
        alert("必须包含大写字母 小写字母 数字 8到10位")

      }
      if (!(emailReg.test(emailVal))) {
        flag = false;
        alert("邮箱不符合规则")
      }
      if (!(phoneReg.test(phoneVal))) {
        flag = false;
        alert("手机号不符合规则")
      }
      if (!(idCardReg.test(idcardVal))) {
        flag = false;
        alert("身份证号不符合规则")
      }

      if (flag) {
        alert("我要像后台发送数据了")
      } else {
        return
      }
    }

  </script>
</body>

</html>